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Conventions 



Register and bit mnemonics are defined in the paragraphs describing them. 

An overbar is used to designate an active-low signal, eg: RESET. 

Unless otherwise stated, blank cells in a register diagram indicate that the bit is 
either unused or reserved; shaded cells indicate that the bit is not described in the 
following paragraphs; 'u' is used to indicate an undefined state (on reset). 
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1 

GENERAL DESCRIPTION 

The MC68HC05SU3A HCMOS microcontroller is a member of the M68HC05 family of low-cost 
single-chip microcontrollers. This 8-bit microcontroller unit (MCU) contains on-chip oscillator, 
CPU, RAM, ROM, I/O, and Timer. The MC68HC05SU3A is pin compatible with the MC6805U3 
and is provided as a low power upgrade path for MC6805U3 applications. The low power 
advantage of CMOS is combined with the addition of I/O and port modifications which help 
eliminate external components in cost sensitive applications. 



1.1 Features 

• Fully static chip design featuring the industry standard 8-bit M68HC05 core 

• Pin compatible with the MC6805U3 

• Power saving STOP, WAIT, and SLOW modes 

• 3840 bytes of user ROM with security feature 

• 1 92 bytes of user RAM (64 bytes for stack) 

• 32 bidirectional I/O lines 

• Keyboard interrupts 

• 8-bit count-down timer with programmable 7-bit prescaler 

• On-chip crystal oscillator, with built-in capacitor for RC option 

• Second software programmable external interrupt line (IRQ2) 

• Direct LED drive capability on all ports 

• Programmable 20KO. pull-up resistors integrated into I/O ports 
(1.9K£2 pull-up resistors integrated into PBO and PB1) 

Internal 60Kfl pull-up resistor on RESET pin 

Internal 100Kfi pull-up resistor on IRQ pin 

• Low Voltage Reset 

• Available in 40-pin PDIP, 42-pin SDIP and 44-pin QFP packages 
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1.2 Mask Options 

The following mask options are available: 

• RC or Crystal Oscillator (see Section 2.2). The default is crystal option. 

• IRQ pull-up resistor — enabled or disabled. 

• Power-On Reset delay — Table 1-1 shows available options. The default value is 4096 
cycles. 



Table 1-1 Power-On Reset Delay Mask Option 



Power-On Reset Delay 
(cycles) 

256 
512 
1024 
2048 
4096 
8192 
16384 
32768 



• Power-On Reset Slow mode. If enabled, the device goes into Slow mode directly upon 
power-on reset. The bus frequency is 16 times slower than the normal mode. Thus, the 
power-on reset delay will also be 16 times longer. The default setting is "Slow mode" 
disabled. 



1.3 MCU Structure 

Figure 1-1 shows a block diagram of the MC68HC05SU3A MCU. 
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Figure 1-1 MC68HC05SU3A Block Diagram 
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2 

PIN DESCRIPTIONS 

This section provides a description of the functional pins of the MC68HC05SU3A microcontroller. 



2.1 Functional Pin Descriptions 



PIN NAME 


40-pin PDIP 
PIN No. 


42-pin SDIP 
PIN No. 


44-pin QFP 
PIN No. 


DESCRIPTION 


VDD 
VSS 

VSS(INT) 
VSS(EXT) 


4 
1 


5 

1 

2 


10,33 
32 
6 
7 


Power is supplied to the MCU using these pins. 
VDD should be connected to the positive supply. 
VSS, VSS(INT), and VSS(EXT) should be connected to 
supply ground. 


VPP 


7 


8 


13 


This is not used, it should be connected to VDD or VSS. 


IRQ 


3 


4 


9 


IRQ is software programmable to provide two choices of 
interrupt triggering sensitivity. These options are: 

1) negative-edge-sensitive triggering only, or 

2) both negative-edge-sensitive and level-sensitive 
triggering. 

This pin has an integrated pull-up resistor to VDD but should 
be tied to VDD if not needed to improve noise immunity. The 
IRU pin contains an internal Schmitt trigger as part of its 
input to improve noise immunity. The voltage on this pin may 
affect the mode of operation as described in Section 9. 


RESET 


2 


3 


8 


This pin can be used as an input to reset the MCU to a 
known start-up state by pulling it to the low state. The 
RESET pin contains an internal Schmitt trigger to improve 
its noise immunity as an input. It also has an internal 
pull-down device that pulls the RESET pin low during the 
power-on reset cycles and an integrated pull-up resistor to 
VDD. 


TIMER 


8 


9 


14 


The TIMER pin provides an optional gating input to the timer. 
Refer to Section 6 for additional information. 


0SC1.0SC2 


5,6 


6,7 


11, 12 


The OSC1 and OSC2 pins are the connections for the 
on-chip oscillator. See Section 2.2 for detail. 
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PIN NAME 


40-pin PDIP 
PIN No. 


42-pin SDIP 
PIN No. 


44-pin QFP 
PIN No. 


DESCRIPTION 


PA0-PA7 


33-40 


34-41 


42-44, 1-5 


These eight I/O lines comprise port A. The state of any pin 
is software programmable. All port A lines are configured as 
input during power-on or external reset. 
PA0-PA7 are also associated with the Keyboard interrupt 
function. Each pin is equipped with a programmable 
integrated 20KQ. pull-up resistor connected to VDD when 
configured as input. When programmed as output, each pin 
can provide a current drive of 1 0mA. See Section 3 for 
details on the I/O ports. 


PB0-PB7 


25-32 


26-33 


31,35-41 


These eight I/O lines comprise port B. The state of any pin 
is software programmable. All port B lines are configured as 
input during power-on or external reset. 
PB0 and PB1 are equipped with an integrated 1 MQ. pull-up 
resistor. PB2-PB7 are equipped with a programmable 
integrated 20KH pull-up resistor connected to VDD when 
configured as input. When programmed as output, each pin 
can provide a current drive of 10mA. PB5-PB7 can also be 
programmed to provide a lower current drive of 2mA. See 
Section 3 for details on the I/O ports. 


PC0-PC7 


9-16 


10-17 


15-22 


These eight I/O lines comprise port C.The state of any pin 
is software programmable. All port C lines are configured as 
input during power-on or external reset. 
Each pin is equipped with a programmable integrated 20KI2 
pull-up resistor connected to VDD when configured as input. 
When programmed as output, each pin can provide a 
current drive of 10mA. See Section 3 for details on the I/O 
ports. 


PD0-PD7 
IRQ2 


24-21,20-17 
18 


25-22,21-18 
19 


30-23 
24 


These eight I/O lines comprise port D. The state of any pin 
is software programmable. All port D lines are configured as 
input during power-on or external reset. 
Each pin is equipped with a programmable integrated 20KI2 
pull-up resistor connected to VDD when configured as input. 
When programmed as output, each pin can provide a 
current drive of 10mA. 

PD6 is configured as 1RQ2 by setting IRQ2E in the 
Miscellaneous Control Register ($0C). 
See Section 3 for details on the I/O ports. 



2.2 OSC1 and OSC2 Connections 

The OSC1 and OSC2 pins are the connections for the on-chip oscillator — the following 
configurations are available: 

1 ) A crystal or ceramic resonator as shown in Figure 2-1 (a). 

2) An external clock signal as shown in Figure 2-1 (b). 

3) RC options as shown in Figure 2-1 (c) and Figure 2-1 (d). 

The external oscillator clock frequency, f osc , is divided by two to produce the internal operating 
frequency, f p- 
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MCU 

0SC1 0SC2 




MCU 

0SC1 0SC2 



Unconnected 
- External Clock 



(a) Crystal or ceramic resonator connections 



(b) External clock source connection 



MCU 



OSC1 



OSC2 



Vdd 



o 

Unconnected 
(c) RC option 1 - external resistor 



MCU 

OSC1 


OSC2 









(d) RC option 2 - internal resistor 



Figure 2-1 Oscillator Connections 

2.2.1 Crystal Oscillator 

The circuit in Figure 2-1 (a) shows a typical oscillator circuit for an AT-cut, parallel resonant crystal. 
The crystal manufacturer's recommendations should be followed, as the crystal parameters 
determine the external component values required to provide maximum stability and reliable 
start-up. The load capacitance values used in the oscillator circuit design should include all stray 
capacitances. The crystal and components should be mounted as close as possible to the pins for 
start-up stabilization and to minimize output distortion. An external start-up resistor of 
approximately 10Mii is needed between OSC1 and OSC2 for the crystal type oscillator. 



2.2.2 



External Clock 



An external clock from another CMOS-compatible device can be connected to the OSC1 input, 
with the OSC2 input not connected, as shown in Figure 2-1 (b). 



MC68HC05SU3A 
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2.2.3 RC Oscillator Option 

This configuration is intended to be the lowest cost option in applications where oscillator accuracy 
is not important. An internal constant current source and a capacitor have been integrated on-chip, 
connected between the OSC2 pin and VSS. Thus by either connecting a resistor to VDD from 
OSC2 or by putting a wire strap between OSC1 and OSC2 self-oscillations at the frequency as 
shown in Figure 2-2 and Figure 2-3 can be induced. 




Resistance (K£2) 



Figure 2-2 Typical Oscillator Frequency for Selected External Resistor 




Figure 2-3 Typical Oscillator Frequency for Wire-Strap Connection 
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2.3 Pin Assignments 



C3 
C4 



VSS C 
RESET C 
IRQ 
VDD 
0SC1 C 
0SC2 C 

wp C 

TIMER C 
PCO C 
PC1 C 
PC2 C 
PC3 C 
PC4 C 
PC5 C 
PC6 C 
PC7 C 
PD7 C 
PD6/IRQ2 C 
PD5 C 
PD4 C 20 



40 □ PA7 
39 □ PA6 
38 P PA5 
37 
36 
35 



□ PA4 

□ PA3 

□ PA2 
34 □ PA1 
33 □ PAO 
32 □ PB7 
31 □ PB6 



30 □ PB5 
29 □ PB4 
28 □ PB3 
27 □ PB2 
26 □ PB1 
25 □ PBO 
24 □ PDO 
23 □ PD1 
22 □ PD2 
21 □ PD3 



Figure 2-4 Pin Assignment for 40-pin PDIP 
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VSS(INT) [ 
VS S(EXT) [ 
RESET [ 
IRQ [ 
VDD [ 
0SC1 [ 
0SC2 [ 
VPP I 
TIMER [ 
PCO [ 
PC1 [ 
PC2 [ 
PC3 [ 
PC4 [ 
PC5 [ 
PC6 [ 
PC7 [ 
PD7 [ 
PD6/TRQ2 [ 
PD5 [ 
PD4 [ 




Figure 2-5 Pin Assignment for 42-pin SDIP 
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Figure 2-6 Pin Assignment for 44-pin QFP 
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INPUT/OUTPUT PORTS 

The MC68HC05SU3A has 32 bidirectional I/O lines, arranged as four 8-bit I/O ports (Port A, B, C, 
and D). The individual bits in these ports are programmable as either inputs or outputs under 
software control by the Data Direction Registers (DDRs). All port pins (except PBO and PB1 ) each 
has an associated 20KQ. pull-up resistor, which can be connected/disconnected under software 
control. Also, each port pin (except PBO and PB1) is capable of sinking and driving a maximum 
current of 10mA (e.g. direct drive for LEDs). PBO and PB1 each has a permanent 1.9K£2 pull-up 
resistor connected, with 20mA current sink capability. Port A can also be configured for keyboard 
interrupts. 



3.1 Parallel Ports 

Port A, B, C, and D are 8-bit bidirectional ports. Each Port pin is controlled by the corresponding 
bits in a Data Direction Register and a Data Register as shown in Figure 3-1 . The functions of the 
I/O pins are summarized in Table 3-1 . 



Table 3-1 I/O Pin Functions 



R/W 


DDR 


I/O Pin Function 








The I/O pin is in input mode. Data is written into the output data latch. 





1 


Data is written into the output data latch and output to the I/O pin. 


1 





The state of the I/O pin is read. 


1 


1 


The I/O pin is in an output mode. The output data latch is read. 



3.1.1 Port Data Registers 

Each Port I/O pin has a corresponding bit in the Port Data Register. When a Port I/O pin is 
programmed as an output the state of the corresponding data register bit determines the state of 
the output pin. All Port I/O pins can drive a current of 10mA when programmed as outputs. When 
a Port pin is programmed as an input, any read of the Port Data Register will return the logic state 
of the corresponding I/O pin. The locations of the Data Registers for Port A, B, C, and D are at 
$00, $01, $02, and $03 respectively. The Port Data Registers are unaffected by reset. 
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DATA DIRECTION 
REGISTER BIT 



INTERNAL 
MC68HC05 
CONNECTIONS 



LATCHED OUTPUT 
DATA BIT 




OUTPUT 



I/O PIN 




Figure 3-1 Port I/O Circuitry 



3.1.2 Port Data Direction Registers 

Each port pin may be programmed as an input by clearing the corresponding bit in the DDR, or 
programmed as an output by setting the corresponding bit in the DDR. The DDR for Port A, B, C, 
and D are located at $04, $05, $06 and, $07 respectively. The DDRs are cleared by reset. 



Note: A "glitch" may occur on an I/O pin when selecting from an input to an output unless the 
data register is first preconditioned to the desired state before changing the 
corresponding DDR bit from a "0" to a "1". 



3.2 Port A — Keyboard Interrupts (KBI) 

Port A is configured for use as keyboard interrupts when the KBIE bit is set in the Miscellaneous 
Control Register (MCR). Individual keyboard interrupt port pins are also maskable by setting 
corresponding bits in the Keyboard Interrupt Mask Register. 

See Section 5.2.2.4 for details on the keyboard interrupts. 



3.3 PD6 — IRQ2 



The port pin PD6 is configured as IRQ2 by setting the IRQ2E bit in the MCR. The external interrupt 
IRQ2 behaves similar to IRQ except it is edge-triggered only, and does not have wake-up function 
in STOP mode. 

See Section 5.2.2.2 for details on the external interrupt IRQ2. 
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3.4 Programmable Current Drive 

All I/O ports (except PBO and PB1), when programmed as outputs, can source or sink a current 
of 10mA for driving LEDs directly. By setting the PIL bit in the Port Option Register (at $0A), 
PB5-PB7 can be programmed to a low-current mode that source or sink only a current of 2mA 
when programmed as output. This allows a direct drive to low current LEDs. 

Note: Although the ports each has high current drive capability, designs should limit the total 
port currents to not more than 1 00mA. 



3.5 Programmable Pull-Up Devices 

Ports B, C, and D have 20K£2 pull-up resistors, which can be connected or disconnected, by 
setting appropriate bits in the Port Option Register (at $0A). Port pins PBO and PB1 each has a 
permanent 1 .9KQ. pull-up resistor connected. 



3.5.1 Port Option Register 



Port Option Register (POPR) 



Address 


bit 7 


bit 6 


bit 5 


bit 4 


bit 3 


bit 2 


bit 1 


bitO 


State 
on reset 


$0A 






PIL 


PDP 


PCP 


PBP 






0000 0000 



PIL — PB5:PB7 current drive select 

1 (set) - PB5-PB7 are configured to 2mA drive port. 

(clear) - PB5-PB7 are configured to 10mA drive port. 

PDP — Port D Pull-up 

1 (set) - The internal 20K£2 pull-up resistors are connected to the inputs of 

Port D. 

(clear) - No pull-up resistor is connected to the inputs of Port D. 

PCP — Port C Pull-up 

1 (set) - The internal 20K£2 pull-up resistors are connected to the inputs of 

Port C. 

(clear) - No pull-up resistor is connected to the inputs of Port C. 

PBP — PB2:PB7 Pull-up 

1 (set) - The internal 20K£2 pull-up resistors are connected to the inputs of 

PB2-PB7. 

(clear) - No pull-up resistor is connected to the inputs of PB2-PB7. 
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4 



MEMORY AND REGISTERS 



The MC68HC05SU3A has 8K-bytes of addressable memory, consisting of I/O registers, user 
ROM, user RAM, and self-check ROM. Figure 4-1 shows the memory map for MC68HC05SU3A 
device. 



4.1 I/O Registers 

The I/O, status and control registers are located within the first 16 bytes of memory, from $0000 
to $000F. These are shown in the memory map in Figure 4-1 ; and a summary of the register 
outline is shown in Table 4-1. Reading from unimplemented bits will return unknown states, and 
writing to unimplemented bits will be ignored. 



4.2 RAM 

The user RAM (including the stack) consists of 192 bytes. It is separated into two blocks at 
locations $0010 to $008F, and $00C0 to $00FF.The stack begins at address $00FF and proceeds 
down to $00C0. 



4.3 ROM 

The user ROM consists of 3840 bytes of memory, from $1000 to $1EFF. Twelve bytes of user 
vectors are also available, from $1 FF4 to $1 FFF. 

Note: Using the stack area for data storage or temporary work locations requires care to 
prevent the data from being overwritten due to stacking from an interrupt or subroutine 
call. 
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4.4 Memory Map 

Figure 4-1 shows the memory map for MC68HC05SU3A device. 



I/O 
16 Bytes 



User RAM 
128 Bytes 



Stack 
64 Bytes 



Unused 



User ROM 
3840 Bytes 



Self-Check 
240 Bytes 



User Vectors 
12 Bytes 



Ports 



Timer Registers 
2 Bytes 



Port Option Register 



KBI Register 



Misc. Register 



Reserved 



Reserved 
2 Bytes 






Port A Data Register 


soo 




Port B Data Register 


S01 




Port C Data Register 


S02 




Port D Data Register 


S03 




Port A Data Direction Register 


S04 




Port B Data Direction Register 


505 




Port C Data Direction Register 


S06 




Port D Data Direction Register 


S07 




Timer Data Register 


S08 




Timer Control Register 


S09 




Port Option Register 


SOA 




Keyboard Interrupt Mask Register 


SOB 




Miscellaneous Control Register 


SOC 


15 


Reserved 


SOD 




Reserved 


SOE 




Reserved 


SOF 



S1FF0 


Reserved 


S1FF2 


Reserved 


$1FF4 


KBI 


S1FF6 


Timer 


S1FF8 


IRQ2 


$1 FFA 


IRQ 


$1FFC 


SWI 


$1FFE 


RESET 



Figure 4-1 MC68HC05SU3A Memory Map 
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4.5 I/O Registers Summary 

Table 4-1 shows a summary of I/O registers for MC68HC05SU3A device. 



Table 4-1 MC68HC05SU3A I/O Registers 



Register Name 


Address 


bit 7 


bit 6 


bit 5 


bit 4 


bit 3 


bit 2 


bit 1 


bitO 


State 
on reset 


Port A Data 


$00 


PA7 


PA6 


PA5 


PA4 


PA3 


PA2 


PA1 


PA0 


unaffected 


Port B Data 


$01 


PB7 


PB6 


PB5 


PB4 


PB3 


PB2 


PB1 


PB0 


unaffected 


Port C Data 


$02 


PC7 


PC6 


PC5 


PC4 


PC3 


PC2 


PC1 


PC0 


unaffected 


Port D Data 


$03 


PD7 


PD6 


PD5 


PD4 


PD3 


PD2 


PD1 


PD0 


unaffected 


Port A Data Direction 


$04 


DDRA7 


DDRA6 


DDRA5 


DDRA4 


DDRA3 


DDRA2 


DDRA1 


DDRA0 


0000 0000 


Port B Data Direction 


$05 


DDRB7 


DDRB6 


DDRB5 


DDRB4 


DDRB3 


DDRB2 


DDRB1 


DDRB0 


0000 0000 


Port C Data Direction 


$06 


DDRC7 


DDRC6 


DDRC5 


DDRC4 


DDRC3 


DDRC2 


DDRC1 


DDRC0 


0000 0000 


Port D Data Direction 


$07 


DDRD7 


DDRD6 


DDRD5 


DDRD4 


DDRD3 


DDRD2 


DDRD1 


DDRD0 


0000 0000 


Timer Data (TDR) 


$08 


TD7 


TD6 


TD5 


TD4 


TD3 


TD2 


TD1 


TD0 


1111 1111 


Timer Control (TCR) 


$09 


TIF 


TIM 


TCEX 


TINE 


PRER 


PR2 


PR1 


PRO 


0100 -000 


Port Option (POPR) 


$0A 






PIL 


PDP 


PCP 


PBP 






■-00 00- 


KBI Mask (KBIM) 


$0B 


KBE7 


KBE6 


KBE5 


KBE4 


KBE3 


KBE2 


KBE1 


KBE0 


0000 0000 


Miscellaneous Control (MCR) 


$0C 


KBIE 


KBIC 


INTO 


INTE 


LVRE 


SM 


IRQ2F 


IRQ2E 


0001 0000 


Reserved 


$0D 




















Reserved 


$0E 
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5 



RESETS AND INTERRUPTS 



This section describes the reset and interrupt functions on the MCU. 



5.1 



RESETS 



The MC68HC05SU3A can be reset in three ways: 

• by initial Power-On Reset function, (POR) 

• by an active low input to the RESET pin, (RESET) 

• by a Low Voltage Reset, (LVR) 

All of these resets will cause the program to go to the starting address, specified by the contents 
of memory locations $1 FFE and $1 FFF, and cause the interrupt mask (l-bit) of the Condition Code 
Register (CCR) to be set. 



The power-on reset (POR) occurs on power-up to allow the clock oscillator to stabilize. The POR 
is strictly for power-up conditions, and should not be used to detect any drops in power supply 
voltage. 

There is an oscillator stabilization delay of t P0 RL internal processor bus clock cycles after the 
oscillator becomes active. The RESET pin will be pulled down internally during these cycles. If the 
RESET pin is low (by external circuit) at the end of the t P0RL period, the processor remains in the 
reset condition until RESET goes high. 



The RESET input pin is used to reset the MCU to provide an orderly software start-up procedure. 
When using the external reset, the RESET pin must stay low for a minimum of 1-5tcYC- The 
RESET pin is connected to a Schmitt Trigger circuit as part of its input to improve noise immunity. 



5.1.1 



Power-On Reset (POR) 



5.1.2 



RESET Pin 



MC68HC05SU3A 
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5.1 .3 Low Voltage Reset (LVR) 

When the LVR function is enabled, an internal reset is generated if the supply voltage, V DD , drops 
below V LVR . (See Section 1 1 for value of V LVR ). 

This LVR function is enabled by setting the LVRE bit in the Miscellaneous Control Register. 

State 

Address bit 7 bit 6 bit 5 bit 4 bit 3 bit 2 bit 1 bitO , 

on reset 



Miscellaneous Control Register $0C KB.E KBIC INTO .NTE LVRE SM IRQ2F IRQ2E 



0001 0000 



LVRE — Low Voltage Reset Enable 

1 (set) - Low Voltage Reset function enabled. 
(clear) - Low Voltage Reset function disabled. 



5.2 INTERRUPTS 

The MC68HC05SU3A MCU can be interrupted by different sources - four maskable hardware 
interrupt and one non-maskable software interrupt: 

• Software Interrupt Instruction (SWI) 

• External signal on IRQ pin 

• External signal on IRQ2 pin 

• Timer Overflow 

• Keyboard 

If the interrupt mask bit (l-bit) in the Condition Code Register (CCR) is set, all maskable interrupts 
are disabled. Clearing the l-bit enables interrupts. 

Interrupts cause the processor to save the register contents on the stack and to set the interrupt 
mask (l-bit) to prevent additional interrupts. The RTI instruction causes the register contents to be 
recovered from the stack and normal processing to resume. 

Unlike reset, hardware interrupts do not cause the current instruction execution to be halted, but 
are considered pending until the current instruction is complete. The current instruction is the one 
already fetched and being operated on. When the current instruction is complete, the processor 
checks all pending hardware interrupts. If interrupts are not masked (CCR l-bit clear) the 
processor proceeds with interrupt processing; otherwise, the next instruction is fetched and 
executed. Table 5-1 shows the relative priority of all the possible interrupt sources. Figure 5-2 
shows the interrupt processing flow. 
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UNSTACKING 
ORDER 



5 1 

4 2 

3 3 

2 4 

1 5 



STACKING 
ORDER 



$00C0 (BOTTOM OF STACK) 

$00C1 

$00C2 



CONDITION CODE REGISTER 



ACCUMULATOR 



INDEX REGISTER 



PROGRAM COUNTER (HIGH BYTE) 



PROGRAM COUNTER (LOW BYTE) 



$00FD 
$00FE 

$00FF (TOP OF STACK) 



Figure 5-1 Interrupt Stacking Order 



Table 5-1 Reset/Interrupt Vector Addresses 



Register 


Flag Name 


Interrupt 


CPU Interrupt 


Vector Address 


Priority 






Reset 


RESET 


$1FFE-$1 FFF 


highest 






Software 


SWI 


$1 FFC-$1 FFD 










External Interrupt 


IRQ 


$1FFA-$1FFB 










External Interrupt 2 


IRQ2 


$1FF8-$1FF9 






TCR 


TIF 


Timer Overflow 


TIF 


$1 FF6-$1 FF7 










Keyboard 


KBI 


$1 FF4-$1 FF5 


lowest 



5.2.1 Non-maskable Software Interrupt (SWI) 

The software interrupt (SWI) is an executable instruction and a non-maskable interrupt: it is 
execute regardless of the state of the l-bit in the CCR. If the l-bit is zero (interrupt enabled), SWI 
is executed after interrupts that were pending when the SWI was fetched, but before interrupts 
generated after the SWI was fetched. The SWI interrupt service routine address is specified by 
the contents of memory locations $1 FFC and $1 FFD. 
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From RESET 




^Keyboard Interrupt?^ 
N 




Clear 
External Interrupt 
Request Latch 



PC^(S 
CC^ (S 


RSP-1) 
P-2) 
P-3) 
P-4) 






Set 1-bit 


in CCR 



Load Interrupt 
Vectors to 
Program Counter 



Restore Registers 
from Stack 
CC, A, X, PC 



Figure 5-2 Hardware Interrupt Processing Flowchart 
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5.2.2 Maskable Hardware Interrupts 

If the interrupt mask bit (1-bit) of the CCR is set, all maskable interrupts are masked. Clearing the 
1-bit allows interrupt processing to occur. 

Note: The internal interrupt latch is cleared in the first part of the interrupt service routine; 

therefore, one external interrupt pulse could be latched and serviced as soon as the 
1-bit is cleared. 



5.2.2.1 External Interrupt (IRQ) 

The external interrupt IRQ is controlled by two bits in the Miscellaneous Control Register ($0C). 





Address bit 7 


bit 6 bit 5 


bit 4 bit 3 bit 2 bit 1 


bitO s,a \ 
on reset 


Miscellaneous Control Register 


$0C KBIE 


KBIC INTO 


INTE LVRE SM IRQ2F 


IRQ2E 0001 0000 



INTE — INTerrupt Enable 

1 (set) - External interrupt IRQ is enabled. 

(clear) - External interrupt is disabled. 
The external IRQ is default enabled at power-on reset. 

INTO — INTerrupt Option 

1 (set) - Negative-edge sensitive triggering for IRQ. 

(clear) - Negative-level sensitive triggering for IRQ. 

When the signal of the external interrupt pin, IRQ, satisfies the condition selected, an external 
interrupt occurs. The actual processor interrupt is generated only if the interrupt mask bit of the 
condition code register is also cleared. When the interrupt is recognized, the current state of the 
processor is pushed onto the stack and the interrupt mask bit in the Condition Code Register is 
set. This masks further interrupts until the present one is serviced. The service routine address is 
specified by the contents in $1 FFA-$1 FFB. 

The interrupt logic recognizes negative edge transitions and pulses (special case of negative 
edges) on the external interrupt line. Figure 5-3 shows both a block diagram and timing for the 
interrupt line (IRQ) to the processor. The first method is used if pulses on the interrupt line are 
spaced far enough apart to be serviced. The minimum time between pulses is equal to the number 
of cycles required to execute the interrupt service routine plus 21 cycles. Once a pulse occurs, the 
next pulse should not occur until the MCU software has exited the routine (an RTI occurs). The 
second configuration shows several interrupt lines wired-OR to perform the interrupt at the 
processor. Thus, if the interrupt lines remain low after servicing one interrupt, the next interrupt is 
recognized. 
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INTO BIT 




EXTERNAL RESET 

EXTERNAL INTERRUPT 
BEING SERVICED (IRQ ONLY) 



(a) Interrupt Function Diagram 




'iLIH 



Wired ORed / 
Interrupt signals \ 



IRQ 



EDGE SENSITIVE TRIGGER 
CONDITION 



The minimum pulse width t| UH is either 
125ns (V DD =5V) or 250ns (V DD =3V). 
The period t| UL should not be less than 
the number of tcyc cycles it takes to ex- 
ecute the interrupt service routine plus 
21 t CY c cycles. 



LEVEL SENSITIVE TRIGGER 
CONDITION 

if after servicing an jnterrupt the 
external interrupt pin (IRQ) remains 
low, then the next interrupt is 
recognized. Normally used with pull-up 
resistors for wired-OR connection. 



(b) Interrupt Mode Diagram 



Figure 5-3 External Interrupt 
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5.2.2.2 External Interrupt 2 (IRQ2) 



The port pin PD6 is configured as IRQ2 by setting the IRQ2E bit in the MCR.The external interrupt 
IRQ2 behaves similar to IRQ except it is edge-triggered only, and does not have wake-up function 
in STOP mode. 



Miscellaneous Control Register 



Address 


bit 7 


bit 6 


bit 5 


bit 4 


bit 3 


bit 2 


bit 1 


bitO 


State 
on reset 


$0C 


KBIE 


KBIC 


INTO 


INTE 


LVRE 


SM 


IRQ2F 


IRQ2E 


0001 0000 



IRQ2E — IRQ2 Enable 



1 (set) - External interrupt IRQ2 is enabled. 
(clear) - External interrupt IRQ2 is disabled. 



IRQ2F — IRQ2 Flag clear 

This is a write-only bit and always read as "0". 



1 (set) - Writing a "1" clears the IRQ2 interrupt latch. 
(clear) - Writing a "0" has no effect. 



When a negative-edge is sensed on IRQ2 pin, an external interrupt occurs. The actual processor 
interrupt is generated only if the l-bit in the CCR is also cleared. When the interrupt is recognized, 
the current state of the processor is pushed onto the stack and the l-bit in the CCR is set. This 
masks further interrupts until the present one is serviced. The latch for IRQ2 is cleared by reset or 
by writing a "1 " to the IRQ2F bit in the MCR in the interrupt service routine. The interrupt service 
routine address is specified by the contents in $1 FF8-$1 FF9. 



5.2.2.3 Timer Interrupt 

The timer interrupt is generated by the 8-bit timer when a timer overflow has occurred. The 
interrupt enable and flag for the timer interrupt are located in the Timer Control Register. 





Address 


bit 7 


bit 6 bit 5 bit 4 bit 3 bit 2 bit 1 


bito s,a,e t 

on reset 


Timer Control Register (TCR) 


$09 


TIF 


TIM TCEX TINE PREP PR2 PR1 


PRO 0100-100 



TIM — Timer Interrupt Mask 

1 (set) - Timer interrupt is disabled. 
(clear) - Timer interrupt is enabled. 
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TIF — Timer Interrupt Flag 

1 (set) - A timer interrupt (timer overflow) has occurred. 

(clear) - A timer interrupt (timer overflow) has not occurred. 

The l-bit in the CCR must be cleared in order for the timer interrupt to be processed. The interrupt 
will vector to the interrupt service routine at the address specified by the contents in $1 FF6-$1 FF7. 



5.2.2.4 Keyboard Interrupt (KBI) 

Keyboard interrupt function is associated with Port A pins. The keyboard interrupt function is 
enabled by setting the keyboard interrupt enable bit KBIE (bit 7 of MCR at $0C) and the individual 
enable bits KBE0-KBE7 (bits 0-7 of KBIM at $0B). When the KB Ex bit is set, the corresponding 
Port A pin will be configured as an input pin, regardless of the DDR setting, and a 20KO. pull-up 
resistor is connected to the pin, as shown in Figure 5-4. When a high to low transition is sensed 
on the pin, a keyboard interrupt will be generated. An interrupt to the CPU will be generated if the 
l-bit in the CCR is cleared. 

The keyboard interrupt flag should be cleared in the interrupt service routine (by writing a "1" to 
KBIC bit in the MCR at $0C) after the key is debounced. Debouncing will avoid spurious false 
triggering. 

The keyboard interrupt is negative-edge sensitive only, and the interrupt service routine is 
specified by the contents in $1 FF4-$1 FF5. 




Figure 5-4 Keyboard Interrupt Circuitry 
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The KBIE bit in the Miscellaneous Control Register controls the master enable for the keyboard 
interrupts. 





Address 


bit 7 


bit 6 


bit 5 


bit 4 


bit 3 


bit 2 


bit 1 


bitO 


State 
on reset 


Miscellaneous Control Register 


$0C 


KBIE 


KBIC 


INTO 


INTE 


LVRE 


SM 


IRQ2F 


IRQ2E 


0001 0000 



KBIE — KeyBoard Interrupt Enable 

1 (set) - Keyboard interrupts master enabled. 

(clear) - Keyboard interrupts master disabled. 

KBIC — KeyBoard Interrupt Clear 

This is a write-only bit and always read as "0". 

1 (set) - Writing a "1" clears the keyboard interrupt latch. 
(clear) - Writing a "0" has no effect. 



The Keyboard Interrupt Mask Register (KBIMR) masks individual keyboard interrupt pins and 
setting of the internal pull-up resistors on port A. 



KBIMR 



Address 


bit 7 


bit 6 


bit 5 


bit 4 


bit 3 


bit 2 


bit 1 


bitO 


State 
on reset 


$0B 


KBE7 


KBE6 


KBE5 


KBE4 


KBE3 


KBE2 


KBE1 


KBE0 


0000 0000 



KBEx — PAx Keyboard Interrupt Enable 

1 (set) - Keyboard interrupt enabled for PAx. A 20K£2 internal pull-up resistor 
is connected. High to low transition on PAx will cause a keyboard 
interrupt. 

(clear) - Keyboard interrupt for PAx pin is masked. Any transitions on PAx will 
not set any flags. 
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6 

TIMER 

This section describes the operation of the 8-bit count-down timer in the MC68HC05SU3A. 



6.1 Timer Overview 

The MC68HC05SU3A timer block diagram is shown in Figure 6-1. The timer contains a single 8-bit 
software programmable count-down counter with a 7-bit software selectable prescaler. The 
counter may be preset under software control and decrements towards zero. When the counter 
decrements to zero, the timer interrupt flag (TIF bit in Timer Control Register, TCR) is set. Once 
timer interrupt flag is set, an interrupt is generated to the CPU only if the TIM bit in the TCR and 
l-bit in the CCR are cleared. When a interrupt is recognized, after completion of the current 
instruction, the processor proceeds to store the appropriate registers on the stack and then 
fetches the timer interrupt vector from locations $1 FF6 and $1 FF7. 

The counter continues to count after it reaches zero, allowing the software to determine the 
number of internal or external clocks since the timer interrupt flag was set. The counter may be 
read at any time by the processor without disturbing the count. The contents of the counter 
become stable prior to the read portion of a cycle and do not change during the read. The timer 
interrupt flag remains set until cleared by the software. If a write occurs before the timer interrupt 
is served, the interrupt is lost. The timer interrupt flag may also be used as a scanned status bit in 
a non-interrupt mode of operation. 

The prescaler is a 7-bit divider which is used to extend the maximum length of the timer. Bit 0, 1 , 
2 (PRO, PR1 , PR2) of TCR are programmed to choose the appropriate prescaler output which is 
used as the 8-bit counter clock input. The processor cannot write into or read from the prescaler; 
however, its contents can be cleared to all zeros by writing to the PRER bit in the TCR. This will 
allow for truncation-free counting. 

The input clock for the timer sub-system is selectable from internal, external, or a combination of 
internal and external sources. The TCEX and TINE bits in the Timer Control Register selects the 
timer input clock. 
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Timer Data Register ($08) 




8-bit count-down timer counter 



7-bit prescaler counter 



RST 





Overflow 
Detect 
Circuit 




Interrupt Circuit 



Prescaler 
Select 
Logic 
(8 to 1 MUX) 



TIF TIM TCEX TINE PRER PR2 PR1 PRO 



Timer Control Register ($09) 



Clock Source 
Logic 



TIMER 



Internal Processor Clock 



TCEX 


TINE 


Clock Source 








Internal clock to timer 





1 


"AND" of internal clock and TIMER pin to timer 


1 





Input clock to timer disabled 


1 


1 


TIMER pin to timer 



Figure 6-1 Timer Block Diagram 
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6.2 Timer Control Register (TCR) 

The TCR enables the software to control the operation of the timer. 



Address 


bit 7 


bit 6 


bit 5 


bit 4 


bit 3 


bit 2 


bit 1 


bitO 


State 
on reset 


$09 


TIF 


TIM 


TCEX 


TINE 


PRER 


PRE2 


PRE1 


PREO 


0100 -100 



TIF — Timer Interrupt Flag 

1 (set) - The timer has reached a count of zero. 

(clear) - The timer has not reached a count of zero. 

The timer interrupt flag is set when the 8-bit counter decrements to zero. This bit is cleared on 
reset, or by writing a "0" to the TIF bit. 

TIM — Timer Interrupt Mask 

1 (set) - Timer interrupt request to the CPU is masked (disabled). 

(clear) - Timer interrupt request to the CPU is not masked (enabled). 

A reset sets this bit to one; it must then be cleared by software to enable the timer interrupt to the 
CPU. This timer interrupt mask only masks timer interrupt request to the CPU, and does not affect 
counting of the 8-bit counter or the setting of TIF. 

TCEX — Timer Clock External 
TINE — Timer INput Enable 

These two bits selects the source of the timer clock. Reset or power-on clears these bits to zero. 



TCEX 


TINE 


Clock Source 








Internal clock to timer 





1 


"AND" of internal clock and TIMER pin to timer 


1 





Input clock to timer disabled 


1 


1 


TIMER pin to timer 



PRER — PREscaler Reset 

Writing a "1" to this write-only bit will reset the prescaler to zero, which is necessary for any new 
counts set by writing to the Timer Data Register.This bit always reads as zero, and is not affected 
by reset. 
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PR2:PR0 

These three bits enable the program to select the division ratio of the prescaler. On reset, these 
three bits are set to "100", which corresponds to a division ratio of 16. 



PR2 


PR1 


PRO 


Divide Ratio 











1 








1 


2 





1 





4 





1 


1 


8 


1 








16 


1 





1 


32 


1 


1 





64 


1 


1 


1 


128 



6.3 Timer Data Register (TDR) 

The TDR is a read/write register which contains the current value of the 8-bit count-down timer 
counter when read. Reading this register does not disturb the counter operation. 



Address 


bit 7 


bit 6 


bit 5 


bit 4 


bit 3 


bit 2 


bit 1 


bitO 


State 
on reset 


$08 


TD7 


TD6 


TD5 


TD4 


TD3 


TD2 


TD1 


TDO 


1111 1111 



6.4 Operation during Low Power Modes 

The timer ceases counting in STOP mode. When STOP mode is exited by an external interrupt 
(IRQ or KBI), the internal oscillator will resume its operation, followed by internal processor 
stabilization delay. The timer is then cleared to zero and resumes its operation. The TIF bit in the 
TCR will be set. To avoid generating a timer interrupt when exiting STOP mode, it is recommended 
to set the TIM bit prior entering STOP mode. After exiting STOP mode TIF bit can then be cleared. 

The CPU clock halts during the WAIT mode, but the timer remains active. If the interrupts are 
enabled, the timer interrupt will cause the processor to exit the WAIT mode. 



6-4 
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7 

CPU CORE AND INSTRUCTION SET 

This section provides a description of the CPU core registers, the instruction set and the 
addressing modes of the MC68HC05SU3A. 



7.1 Registers 

The MCU contains five registers, as shown in the programming model of Figure 7-1 .The interrupt 
stacking order is shown in Figure 7-2. 



7 











Accumulator 


7 











Index register 


15 7 












Program counter 


15 7 







0|0|0|0|0|0|0|0|1 |1 | 




Stack pointer 


7 







11 


| H | I |N|Z|C| 


Condition code register 



Carry / borrow 
Zero 
Negative 
Interrupt mask 
Half carry 



Figure 7-1 Programming model 



7.1.1 Accumulator (A) 

The accumulator is a general purpose 8-bit register used to hold operands and results of 
arithmetic calculations or data manipulations. 
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Increasing 
memory 
address 



Unstack 



Condition code register 



Accumulator 



Index register 



Program counter high 



Program counter low 



Stack 



Decreasing 
memory 
address 



Figure 7-2 Stacking order 



7.1.2 Index register (X) 

The index register is an 8-bit register, which can contain the indexed addressing value used to 
create an effective address. The index register may also be used as a temporary storage area. 



7.1.3 Program counter (PC) 

The program counter is a 1 6-bit register, which contains the address of the next byte to be fetched. 



7.1 .4 Stack pointer (SP) 

The stack pointer is a 16-bit register, which contains the address of the next free location on the 
stack. During an MCU reset or the reset stack pointer (RSP) instruction, the stack pointer is set to 
location $00FF. The stack pointer is then decremented as data is pushed onto the stack and 
incremented as data is pulled from the stack. 

When accessing memory, the ten most significant bits are permanently set to 000000001 1 .These 
ten bits are appended to the six least significant register bits to produce an address within the 
range of $00C0 to $00FF. Subroutines and interrupts may use up to 64 (decimal) locations. If 64 
locations are exceeded, the stack pointer wraps around and overwrites the previously stored 
information. A subroutine call occupies two locations on the stack; an interrupt uses five locations. 



7.1.5 Condition code register (CCR) 

The CCR is a 5-bit register in which four bits are used to indicate the results of the instruction just 
executed, and the fifth bit indicates whether interrupts are masked. These bits can be individually 
tested by a program, and specific actions can be taken as a result of their state. Each bit is 
explained in the following paragraphs. 

Half carry (H) 

This bit is set during ADD and ADC operations to indicate that a carry occurred between bits 3 and 4. 
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Interrupt (I) 

When this bit is set, all maskable interrupts are masked. If an interrupt occurs while this bit is set, 
the interrupt is latched and remains pending until the interrupt bit is cleared. 

Negative (N) 

When set, this bit indicates that the result of the last arithmetic, logical, or data manipulation was 
negative. 

Zero (Z) 

When set, this bit indicates that the result of the last arithmetic, logical, or data manipulation was 
zero. 

Carry/borrow (C) 

When set, this bit indicates that a carry or borrow out of the arithmetic logical unit (ALU) occurred 
during the last arithmetic operation. This bit is also affected during bit test and branch instructions 
and during shifts and rotates. 



7.2 Instruction set 

The MCU has a set of 62 basic instructions. They can be grouped into five different types as 
follows: 

- Register/memory 

- Read/modify/write 

- Branch 

- Bit manipulation 

- Control 

The following paragraphs briefly explain each type. All the instructions within a given type are 
presented in individual tables. 

This MCU uses all the instructions available in the M1 46805 CMOS family plus one more: the 
unsigned multiply (MUL) instruction. This instruction allows unsigned multiplication of the contents 
of the accumulator (A) and the index register (X). The high-order product is then stored in the 
index register and the low-order product is stored in the accumulator. A detailed definition of the 
MUL instruction is shown in Table 7-1 . 
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7.2.1 



Register/memory Instructions 



Most of these instructions use two operands. The first operand is either the accumulator or the 
index register. The second operand is obtained from memory using one of the addressing modes. 
The jump unconditional (JMP) and jump to subroutine (JSR) instructions have no register 
operand. Refer to Table 7-2 for a complete list of register/memory instructions. 



7.2.2 Branch instructions 

These instructions cause the program to branch if a particular condition is met; otherwise, no 
operation is performed. Branch instructions are two-byte instructions. Refer to Table 7-3. 



7.2.3 Bit manipulation instructions 

The MCU can set or clear any writable bit that resides in the first 256 bytes of the memory space 
(page 0). All port data and data direction registers, timer and serial interface registers, 
control/status registers and a portion of the on-chip RAM reside in page 0. An additional feature 
allows the software to test and branch on the state of any bit within these locations. The bit set, bit 
clear, bit test and branch functions are all implemented with single instructions. For the test and 
branch instructions, the value of the bit tested is also placed in the carry bit of the condition code 
register. Refer to Table 7-4. 

7.2.4 Read/modify/write instructions 

These instructions read a memory location or a register, modify or test its contents, and write the 
modified value back to memory or to the register. The test for negative or zero (TST) instruction is 
an exception to this sequence of reading, modifying and writing, since it does not modify the value. 
Refer to Table 7-5 for a complete list of read/modify/write instructions. 



7.2.5 Control instructions 

These instructions are register reference instructions and are used to control processor operation 
during program execution. Refer to Table 7-6 for a complete list of control instructions. 



Tables for all the instruction types listed above follow. In addition there is a complete alphabetical 
listing of all the instructions (see Table 7-7), and an opcode map for the instruction set of the 
M68HC05 MCU family (see Table 7-8). 



7.2.6 



Tables 



7-4 
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Table 7-1 MUL instruction 



Operation 


X:A <- X*A 


Description 


Multiplies the eight bits in the index register by the eight 
bits in the accumulator and places the 1 6-bit result in the 
concatenated accumulator and index register. 


Condition 
codes 


ii oil 

H : Cleared 
I : Not affected 
N : Not affected 
Z : Not affected 
C : Cleared 


Source 


MUL 


Form 


Addressing mode Cycles Bytes Opcode 
Inherent 11 1 $42 



Table 7-2 Register/memory instructions 







Addressing modes 
























Indexed 


Indexed 


Indexed 






Immediate 


Direct 


Extended 




(no 






(8-bit 




(16-bit 
























offset) 


offset) 


offset) 


Function 


lemonic 


01 

■o 

O 
O 


tn 

01 

S. 
CD 


# Cycles 


01 

■a 
o 
o 


tn 

01 

S. 
CD 


# Cycles 


01 

■a 
o 
o 


V) 
<D 

S. 

CC 


# Cycles 


01 
T3 
O 
O 


tn 

01 

S. 
CC 


# Cycles 


01 

■a 
o 
o 


tn 

01 

S. 
CO 


# Cycles 


01 

■a 
o 
o 


tn 

01 

S. 
CD 


# Cycles 






Q. 

o 




CL 

o 




CL 

O 


*t 


CL 

o 




CL 

o 


*t 


CL 

O 




Load A from memory 


LDA 


A6 


2 


2 


B6 


2 


3 


C6 


3 


4 


F6 




3 


E6 


2 


4 


D6 


3 


5 


Load X from memory 


LDX 


AE 


2 


2 


BE 


2 


3 


CE 


3 


4 


FE 




3 


EE 


2 


4 


DE 


3 


5 


Store A in memory 


STA 








B7 


2 


4 


C7 


3 


5 


F7 




4 


E7 


2 


5 


D7 


3 


6 


Store X in memory 


STX 








BF 


2 


4 


CF 


3 


5 


FF 




4 


EF 


2 


5 


DF 


3 


6 


Add memory to A 


ADD 


AB 


2 


2 


BB 


2 


3 


CB 


3 


4 


FB 




3 


EB 


2 


4 


DB 


3 


5 


Add memory and carry to A 


ADC 


A9 


2 


2 


B9 


2 


3 


C9 


3 


4 


F9 




3 


E9 


2 


4 


D9 


3 


5 


Subtract memory 


SUB 


AO 


2 


2 


BO 


2 


3 


CO 


3 


4 


FO 




3 


EO 


2 


4 


DO 


3 


5 


Subtract memory from A 
with borrow 


SBC 


A2 


2 


2 


B2 


2 


3 


C2 


3 


4 


F2 




3 


E2 


2 


4 


D2 


3 


5 


AND memory with A 


AND 


A4 


2 


2 


B4 


2 


3 


C4 


3 


4 


F4 




3 


E4 


2 


4 


D4 


3 


5 


OR memory with A 


ORA 


AA 


2 


2 


BA 


2 


3 


CA 


3 


4 


FA 




3 


EA 


2 


4 


DA 


3 


5 


Exclusive OR memory with A 


EOR 


A8 


2 


2 


B8 


2 


3 


C8 


3 


4 


F8 




3 


E8 


2 


4 


D8 


3 


5 


Arithmetic compare A 
with memory 


CMP 


A1 


2 


2 


B1 


2 


3 


C1 


3 


4 


F1 




3 


E1 


2 


4 


D1 


3 


5 


Arithmetic compare X 
with memory 


CPX 


A3 


2 


2 


B3 


2 


3 


C3 


3 


4 


F3 




3 


E3 


2 


4 


D3 


3 


5 


Bit test memory with A 
(logical compare) 


BIT 


A5 


2 


2 


B5 


2 


3 


C5 


3 


4 


F5 




3 


E5 


2 


4 


D5 


3 


5 


Jump unconditional 


JMP 








BC 


2 


2 


CC 


3 


3 


FC 




2 


EC 


2 


3 


DC 


3 


4 


Jump to subroutine 


JSR 








BD 


2 


5 


CD 


3 


6 


FD 




5 


ED 


2 


6 


DD 


3 


7 
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Table 7-3 Branch instructions 





Relative addressing mode 


Function 


Mnemonic 


Opcode 


# Bytes 


# Cycles 


Branch always 


BRA 


20 


2 


3 


Branch never 


BRN 


21 


2 


3 


Branch if higher 


BHI 


22 


2 


3 


Branch if lower or same 


BLS 


23 


2 


3 


Branch if carry clear 


BCC 


24 


2 


3 


(Branch if higher or same) 


(BHS) 


24 


2 


3 


Branch if carry set 


BCS 


25 


2 


3 


(Branch if lower) 


(BIO) 


25 


2 


3 


Branch if not equal 


BNE 


26 


2 


3 


Branch if equal 


BEQ 


27 


2 


3 


Branch if half carry clear 


BHCC 


28 


2 


3 


Branch if half carry set 


BHCS 


29 


2 


3 


Branch if plus 


BPL 


2A 


2 


3 


Branch if minus 


BMI 


2B 


2 


3 


Branch if interrupt mask bit is clear 


BMC 


2C 


2 


3 


Branch if interrupt mask bit is set 


BMS 


2D 


2 


3 


Branch if interrupt line is low 


BIL 


2E 


2 


3 


Branch if interrupt line is high 


BIH 


2F 


2 


3 


Branch to subroutine 


BSR 


AD 


2 


6 



Table 7-4 Bit manipulation instructions 





Addressing modes 


Bit set/clear 


Bit test and branch 


Function 


Mnemonic 


Opcode 


# Bytes 


# Cycles 


Opcode 


# Bytes 


# Cycles 


Branch if bit n is set 


BRSET n (n=0-7) 








2-n 


3 


5 


Branch if bit n is clear 


BRCLR n (n=0-7) 








01+2-n 


3 


5 


Set bit n 


BSET n (n=0-7) 


10+2-n 


2 


5 








Clear bit n 


BCLR n (n=0-7) 


11+2-n 


2 


5 
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Table 7-5 Read/modify/write instructions 



Addressing modes 





Inherent 
(A) 


Inherent 

(X) 


Direct 


Indexe 
(no 
offset 


d 

) 


Indexed 
(8-bit 
offset) 


rUNUUUN 


Mnemonic 


Opcode 


# Bytes 


# Cycles 


Opcode 


# Bytes 


# Cycles 


Opcode 


# Bytes 


# Cycles 


Opcode 


# Bytes 


# Cycles 


Opcode 


# Bytes 


# Cycles 


increment 


INC 


4C 




3 


5C 




3 


3C 


2 


5 


7C 




5 


6C 


2 


6 


Decrement 


DEC 


4A 




3 


5A 




3 


3A 


2 


5 


7A 




5 


6A 


2 


6 


Clear 


CLR 


4F 




3 


5F 




3 


3F 


2 


5 


7F 




5 


6F 


2 


6 


Complement 


COM 


43 




3 


53 




3 


33 


2 


5 


73 




5 


63 


2 


6 


Negate (two's complement) 


NEG 


40 




3 


50 




3 


30 


2 


5 


70 




5 


60 


2 


6 


Rotate left through carry 


ROL 


49 




3 


59 




3 


39 


2 


5 


79 




5 


69 


2 


6 


Rotate right through carry 


ROR 


46 




3 


56 




3 


36 


2 


5 


76 




5 


66 


2 


6 


Logical shift left 


LSL 


48 




3 


58 




3 


38 


2 


5 


78 




5 


68 


2 


6 


Logical shift right 


LSR 


44 




3 


54 




3 


34 


2 


5 


74 




5 


64 


2 


6 


Arithmetic shift right 


ASR 


47 




3 


57 




3 


37 


2 


5 


77 




5 


67 


2 


6 


Test for negative or zero 


TST 


4D 




3 


5D 




3 


3D 


2 


4 


7D 




4 


6D 


2 


5 


Multiply 


MUL 


42 




11 



























Table 7-6 Control instructions 





Inherent addressing mode 


Function 


Mnemonic 


Opcode 


# Bytes 


# Cycles 


Transfer A to X 


TAX 


97 




2 


Transfer X to A 


TXA 


9F 




2 


Set carry bit 


SEC 


99 




2 


Clear carry bit 


CLC 


98 




2 


Set interrupt mask bit 


SEI 


9B 




2 


Clear interrupt mask bit 


CLI 


9A 




2 


Software interrupt 


SWI 


83 




10 


Return from subroutine 


RTS 


81 




6 


Return from interrupt 


RTI 


80 




9 


Reset stack pointer 


RSP 


9C 




2 


No-operation 


NOP 


9D 




2 


Stop 


STOP 


8E 




2 


Wait 


WAIT 


8F 




2 
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Table 7-7 Instruction set 



Addressing modes 



Condition codes 





INH 


IMM 


DIR 


EXT 


REL 


IX 


1X1 


IX2 


BSC 


BTB 


H 


I 


N 


z 


C 


ADC 

























• 











ADD 

























• 











AND 






















• 


• 








• 


ASL 






















• 


• 











ASR 






















• 


• 











BCC 






















• 


• 


• 


• 


• 


BCLR 






















• 


• 


• 


• 


• 


BCS 






















• 


• 


• 


• 


• 


BEQ 






















• 


• 


• 


• 


• 


BHCC 






















• 


• 


• 


• 


• 


BHCS 






















• 


• 


• 


• 


• 


BHI 






















• 


• 


• 


• 


• 


BHS 






















• 


• 


• 


• 


• 


BIH 






















• 


• 


• 


• 


• 


BIL 






















• 


• 


• 


• 


• 


BIT 






















• 


• 






• 


BLO 






















• 


• 


• 


• 


• 


BLS 






















• 


• 


• 


• 


• 


BMC 






















• 


• 


• 


• 


• 


BMI 






















• 


• 


• 


• 


• 


BMS 






















• 


• 


• 


• 


• 


BNE 






















• 


• 


• 


• 


• 


BPL 






















• 


• 


• 


• 


• 


BRA 






















• 


• 


• 


• 


• 


BRN 






















• 


• 


• 


• 


• 


BRCLR 

































BRSET 

































BSET 
































BSR 
































CLC 

































CLI 
































CLR 





























1 




CMP 




































Address mode abbreviations 



BSC Bit set/clear 

BTB Bit test & branch 

DIR Direct 

EXT Extended 

INH Inherent 



IMM 

IX 

1X1 

IX2 



Immediate 
Indexed (no offset) 
indexed, 1 byte offset 
Indexed, 2 byte offset 



H Half carry (from bit 3) 



Condition code symbols 

q Tested and set if true, 
cleared otherwise 



REL Relative 
Not implemented 



I Interrupt mask 

N Negate (sign bit) 

Z Zero 

C Carry/borrow 



Not affected 

Load CCR from stack 

Cleared 

Set 
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Table 7-7 Instruction set (Continued) 



Mnpmnnir 

lull ICll IUI I1L 


Addressing modes 


Condition codes 


INH 


IMM 


DIR 


EXT 


REL 


IX 


1X1 


1X2 


BSC 


BTB 


H 


1 


N 


z 


c 


COM 






















• 


• 








1 


CPX 






















• 


• 











DEC 






















• 


• 








• 


EOR 






















• 


• 








• 


INC 






















• 


• 








• 


JMP 






















• 


• 


• 


• 


• 


JSR 






















• 


• 


• 


• 


• 


LDA 






















• 


• 








• 


LDX 






















• 


• 








• 


LSL 






















• 


• 











LSR 






















• 


• 











MUL 
























• 


• 


• 





NEG 






















• 


• 











NOP 






















• 


• 


• 


• 


• 


ORA 






















• 


• 








• 


ROL 






















• 


• 











ROR 






















• 


• 











RSP 






















• 


• 


• 


• 


• 


RTI 


























1 






RTS 






















• 


• 


• 


• 


• 


SBC 






















• 


• 











SEC 






















• 


• 


• 


• 


1 


SEI 






















• 




• 


• 


• 


STA 






















• 


• 








• 


STOP 
































STX 


































SUB 


































SWI 
































TAX 
































TST 


































TXA 
































WAIT 


































Address mode abbreviations 

BSC Bit set/clear IMM Immediate 



BTB Bit test & branch 

DIR Direct 

EXT Extended 

INH Inherent 



IX Indexed (no offset) 

1X1 Indexed, 1 byte offset 

IX2 Indexed, 2 byte offset 

REL Relative 

Not implemented 



Condition code symbols 

Half carry (from bit 3) 



I Interrupt mask 

N Negate (sign bit) 

Z Zero 

C Carry/borrow 



Tested and set it true, 
cleared otherwise 
Not affected 
Load CCR from stack 
Cleared 
Set 
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Table 7-8 M68HC05 opcode map 




Freescale Semiconductor, Inc. 



7.3 Addressing modes 

Ten different addressing modes provide programmers with the flexibility to optimize their code for 
all situations. The various indexed addressing modes make it possible to locate data tables, code 
conversion tables and scaling tables anywhere in the memory space. Short indexed accesses are 
single byte instructions; the longest instructions (three bytes) enable access to tables throughout 
memory. Short absolute (direct) and long absolute (extended) addressing are also included. One 
or two byte direct addressing instructions access all data bytes in most applications. Extended 
addressing permits jump instructions to reach all memory locations. 

The term 'effective address' (EA) is used in describing the various addressing modes. The 
effective address is defined as the address from which the argument for an instruction is fetched 
or stored. The ten addressing modes of the processor are described below. Parentheses are used 
to indicate 'contents of the location or register referred to. For example, (PC) indicates the 
contents of the location pointed to by the PC (program counter). An arrow indicates 'is replaced 
by' and a colon indicates concatenation of two bytes. For additional details and graphical 
illustrations, refer to the M6805 HMOS/M146805 CMOS Family Microcomputer/ 
Microprocessor User's Manual or to the M68HC05 Applications Guide. 



7.3.1 Inherent 

In the inherent addressing mode, all the information necessary to execute the instruction is 
contained in the opcode. Operations specifying only the index register or accumulator, as well as 
the control instruction, with no other arguments are included in this mode. These instructions are 
one byte long. 



7.3.2 Immediate 

In the immediate addressing mode, the operand is contained in the byte immediately following the 
opcode. The immediate addressing mode is used to access constants that do not change during 
program execution (e.g. a constant used to initialize a loop counter). 

EA = PC+1 ; PC <- PC+2 



7.3.3 Direct 

In the direct addressing mode, the effective address of the argument is contained in a single byte 
following the opcode byte. Direct addressing allows the user to directly address the lowest 256 
bytes in memory with a single two-byte instruction. 

EA = (PC+1); PC <- PC+2 
Address bus high <- 0; Address bus low <- (PC+1) 
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7.3.4 



Extended 



In the extended addressing mode, the effective address of the argument is contained in the two 
bytes following the opcode byte. Instructions with extended addressing mode are capable of 
referencing arguments anywhere in memory with a single three-byte instruction. When using the 
Motorola assembler, the user need not specify whether an instruction uses direct or extended 
addressing. The assembler automatically selects the short form of the instruction. 



7.3.5 Indexed, no offset 

In the indexed, no offset addressing mode, the effective address of the argument is contained in 
the 8-bit index register. This addressing mode can access the first 256 memory locations. These 
instructions are only one byte long. This mode is often used to move a pointer through a table or 
to hold the address of a frequently referenced RAM or I/O location. 



7.3.6 Indexed, 8-bit offset 

In the indexed, 8-bit offset addressing mode, the effective address is the sum of the contents of 
the unsigned 8-bit index register and the unsigned byte following the opcode. Therefore the 
operand can be located anywhere within the lowest 51 1 memory locations. This addressing mode 
is useful for selecting the mth element in an n element table. 



7.3.7 Indexed, 16-bit offset 

In the indexed, 16-bit offset addressing mode, the effective address is the sum of the contents of 
the unsigned 8-bit index register and the two unsigned bytes following the opcode. This address 
mode can be used in a manner similar to indexed, 8-bit offset except that this three-byte instruction 
allows tables to be anywhere in memory. As with direct and extended addressing, the Motorola 
assembler determines the shortest form of indexed addressing. 



EA = (PC+1):(PC+2); PC <- PC+3 
Address bus high <- (PC+1 ); Address bus low <- (PC+2) 



EA = X; PC <- PC+1 
Address bus high <- 0; Address bus low <- X 



EA = X+(PC+1);PC^PC+2 
Address bus high <— K; Address bus low <- X+(PC+1) 
where K = the carry from the addition of X and (PC+1) 



EA = X+[(PC+1):(PC+2)]; PC <- PC+3 
Address bus high <- (PC+1 )+K; Address bus low <- X+(PC+2) 
where K = the carry from the addition of X and (PC+2) 
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7.3.8 Relative 

The relative addressing mode is only used in branch instructions. In relative addressing, the 
contents of the 8-bit signed byte (the offset) following the opcode are added to the PC if, and only 
if, the branch conditions are true. Otherwise, control proceeds to the next instruction. The span of 
relative addressing is from -126 to +129 from the opcode address. The programmer need not 
calculate the offset when using the Motorola assembler, since it calculates the proper offset and 
checks to see that it is within the span of the branch. 

EA = PC+2+(PC+1); PC <- EA if branch taken; 
otherwise EA = PC <- PC+2 



7.3.9 Bit set/clear 

In the bit set/clear addressing mode, the bit to be set or cleared is part of the opcode. The byte 
following the opcode specifies the address of the byte in which the specified bit is to be set or 
cleared. Any read/write bit in the first 256 locations of memory, including I/O, can be selectively 
set or cleared with a single two-byte instruction. 

EA = (PC+1); PC ^ PC+2 
Address bus high <- 0; Address bus low <- (PC+1) 



7.3.10 Bit test and branch 

The bit test and branch addressing mode is a combination of direct addressing and relative 
addressing. The bit to be tested and its condition (set or clear) is included in the opcode. The 
address of the byte to be tested is in the single byte immediately following the opcode byte (EA1 ). 
The signed relative 8-bit offset in the third byte (EA2) is added to the PC if the specified bit is set 
or cleared in the specified memory location. This single three-byte instruction allows the program 
to branch based on the condition of any readable bit in the first 256 locations of memory. The span 
of branch is from -125 to +130 from the opcode address. The state of the tested bit is also 
transferred to the carry bit of the condition code register. 

EA1 = (PC+1); PC <- PC+2 
Address bus high <- 0; Address bus low <- (PC+1) 
EA2 = PC+3+(PC+2); PC <- EA2 if branch taken; 
otherwise PC <- PC+3 
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8 

LOW POWER MODES 

The MC68HC05SU3A has three low-power operating modes. The WAIT and STOP instructions 
provide two modes that reduce the power required for the MCU by stopping various internal clocks 
and/or the on-chip oscillator. The flow of the STOP and WAIT modes is shown in Figure 8-1 . The 
third low-power operating mode is the SLOW mode. 



8.1 STOP Mode 

Execution of the STOP instruction places the MCU in its lowest power consumption mode. In the 
STOP mode the internal oscillator is turned off, halting all internal processing. 

When the CPU enters STOP mode the l-bit in the Condition Code Register is cleared 
automatically, so that hardware interrupts, IRQ and KBI can "wake" the MCU. All other registers 
and memory contents remain unaltered. All input/output lines remain unchanged. 

The MCU can be brought out of the STOP mode only by a hardware interrupt or an externally 
generated reset. When exiting the STOP mode the internal oscillator will resume after a 
pre-defined number of internal processor clock cycles, due to oscillator stabilization. 



8.2 WAIT Mode 

The WAIT instruction places the MCU in a low-power mode, but consumes more power than the 
STOP mode. In the WAIT mode the internal processor clock is halted, suspending all processor 
and internal bus activities. Other Internal clocks remain active, permitting interrupts to be 
generated from the Timer. The Timer may be used to generate a periodic exit from the WAIT mode 
or, in conjunction with the external Timer pin, on the occurrence of external events. Execution of 
the WAIT instruction automatically clears the l-bit in the Condition Code Register, so that any 
hardware interrupt can "wake" the MCU. All other registers, memory, and input/output lines remain 
in their previous states. 
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Figure 8-1 STOP and WAIT Mode Flowcharts 
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8.3 SLOW Mode 

The SLOW mode function is controlled by the SM bit in the Miscellaneous Control Register. When 
the SM bit is set, the internal bus clock is divided by 16, resulting to a frequency equal to the 
oscillator frequency divide by 32. This feature permits a slow down of all the internal operations 
and thus reduces power consumption — particularly useful while in WAIT mode. The SM bit is 
automatically cleared while going to STOP mode. 





Address 


bit 7 


bit 6 bit 5 


bit 4 


bit 3 


bit 2 


bit 1 bit 


State 
on reset 


Miscellaneous Control Register 


$0C 










SM 




0001 0000 



SM — Slow Mode 

1 (set) - Slow mode enabled. Internal bus frequency fop=fosc ^ 32 - 
(clear) - Slow mode disabled. Internal bus frequency fop=fosc + 2 - 
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9 



OPERATING MODES 



The MC68HC05SU3A has two modes of operation: the User Mode and the Self-Check Mode. 
Table 9-1 shows the conditions required for entering the two operating modes. 



Table 9-1 Mode Selection 



RESET 


Vpp 


PB1 


MODE 




Vss t0 Vdd 


Vss t0 Vdd 


USER 


Vtst 


Vdd 


SELF-CHECK 



v tst 



=2xV, 



DD 



9.1 



User Mode 



The normal operating mode of the MC68HC05SU3A is the User mode. This mode is entered on 
the rising edge of RESET when the V PP and PB1 pins are between V ss and V DD . 



9.2 



Self-Check Mode 



The Self-check mode is provided on the MC68HC05SU3A for the user to check device functions 
with an on-chip self-check program masked at location $1 F00 to $1 FEF under minimum hardware 
support. The self-check schematic is shown in Figure 9-1. Self-check mode is entered on the 
rising edge of RESET when the V PP pin is at V TST (2xV DD ) and PB1 pin is at V DD . Once in the 
self-check mode, PB1 can then be used for other purposes. After entering the self-check mode, 
CPU branches to the self-check program and carries out the self-check. Self-check is a repetitive 
test, i.e. if all parts are checked to be good, the CPU will repeat the self-check again. Therefore, 
the LEDs attached to Port A will be flashing if the device is good; else the combination of LEDs' 
on-off pattern can show what part of the device is suspected to be bad. Table 9-2 lists the LEDs' 
on-off patterns and their corresponding indications. 
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OUT 



Crystal OSC 



4MHz 



+5V 



I 



4K7 



RESET 

i — o 



IjlF; 



+5V 



+5V 



330 D \// 



330 ° 2 // 



330 D3 // 
330 04 // 



10K 



MC68HC05SU3 




PAO 




PA1 




PA2 




PA3 


OSC1 


PA4 




PA5 


OSC2 


PA6 




PA7 




PDO 




PD1 




PD2 




PD3 




PD4 




PD5 




PD6/IRQ2 




PD7 


RESET 


PCO 




PC1 




PC2 




PC3 




PC4 




PC5 




PC6 




PC7 


PBO 






IRQ 


PB4 




TIMER 


PB1 




PB5 




PB2 




PB6 


VPP 


PB3 


VDD 


PB7 


VSS 



VPP 



+5V 



4, 



0.1|iF 



47^F 



Figure 9-1 MC68HC05SU3A Self-Check Circuit 
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Table 9-2 Self-Check Report 



D4 


D3 


D2 


D1 


REMARKS 


Flashing 


O.K. (self-check is on-going) 




1 


1 


1 


Bad port A 




1 


1 





Bad port B 




1 





1 


Bad port C 




1 








Bad port D 







1 


1 


Bad RAM 







1 





Bad ROM 













Bad SWI 





1 


1 


1 


Bad IRQ 



1 =LED on, = LED off 
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ELECTRICAL SPECIFICATIONS 

This section contains the electrical specifications for MC68HC05SU3A. 

10.1 Maximum Ratings 



(Voltages referenced to V ss ) 



RATINGS 


SYMBOL 


VALUE 


UNIT 


Supply Voltage 


Vdd 


-0.3 to +7.0 


V 


Input Voltage 


V|N 


V ss -0.3 toV DD+ 0.3 


V 


V PP Pin 


V|N 


V ss -0.3 to2xV DD +0.3 


V 


Current Drain per pin excluding V DD and V ss 


b 


25 


mA 


Operating Temperature 




T L toT H 




Standard 


Ta 


to +70 


°C 


Extended 




-40 to +85 




Storage Temperature Range 


T STG 


-65 to +150 


°C 



This device contains circuitry to protect the inputs against damage due to high static voltages or 
electric fields. However, it is advised that normal precautions should be taken to avoid application 
of any voltage higher than the maximum rated voltages to this high impedance circuit. For proper 
operation it is recommended that Vin and Vout be constrained to the range V ss <(V in or V 0Ut )<V DD . 
Reliability of operation is enhanced if unused inputs are connected to an appropriate logic voltage 
level (e.g. either V ss or V DD ). 



10.2 Thermal Characteristics 



CHARACTERISTICS 


SYMBOL 


VALUE 


UNIT 


Thermal resistance 








DIP 


6 JA 


60 


°c/w 


SOIC 


S JA 


60 


°c/w 


QFP 


6 JA 


60 


°c/w 
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10.3 DC Electrical Characteristics 

Table 10-1 DC Electrical Characteristics 



(V DD =5.0Vdc ±10%, V ss =0Vdc, temperature range =0 to 70 °C) 



CHARACTERISTICS 


SYMBOL 


MINIMUM 


TYPICAL 


MAXIMUM 


UNIT 


Output voltage 












Iload = -10^A 


V H 


Vdd-0.1 


— 


— 


V 


Load = +10jxA 


Vol 


— 


— 


0.1 


V 


Output high voltage (I LO ad=-0-8tiA): All Ports 


V H 


Vdd-0-8 


— 


— 


V 


Output low voltage (I|_oad= +1 -6mA): All Ports 


Vol 


— 


— 


0.4 


V 


Output high current 












(V OH =2.5V) All ports 


'oh 


7 


10 


30 


mA 


(V OH =2.0V) PB5-PB7 in low-current mode (25°C) 


1.5 


1.75 


5 


mA 


(V OH =2.0V) PB5-PB7 in low-current mode (0 to 70°C) 




1.25 


1.75 


5 


mA 


Output low current 












(V OL =2.5V) All ports, except PB0 and PB1 




7 


10 


30 


mA 


(V OL =3.0V) PB5-PB7 in low-current mode 


lOL 


2 


3.5 


4.8 


mA 


(V OL =2.5V) PB0, PB1 




40 


70 


— 


mA 


(V OL =0.4V) PB0, PB1 




10 


20 


— 


mA 


Total I/O port current 
Either source or sink 


'port 




1(1(1 




mA 


Input high voltage 

PA0-PA7, PB0, PB1, IRQ, RESET, OSC1 


v„, 

V IH 


fl 7yV n „ 

u./xvdd 




V DD 


\j 


Input low voltage 

PA0-PA7, PB0, PB1, IRQ, RESET, OSC1 


V„ 
V IL 


v ss 






v 


Supply current: 












Run 




— 


5.0 


7.5 


mA 


Wait 


'dd 


— 


1.3 


2.0 


mA 


Stop 25°C 




— 


8 


20 


uA 


0°C to +70°C (Standard) 






10 


30 


u,A 


I/O ports high-Z leakage current 

PA0-PA7, PB2-PB7, PC0-PC7, PD0-PD7 


In 
■ 1 1_ 






±10 


u,A 


Input current 
IRQ, OSC1 


llM 

'IN 






±2 


\ik 


Capacitance 












Ports (as input or output) 


C OUT 






12 


PF 


RESET, IRQ, OSC1,OSC2 


C|N 






8 


PF 


Low voltage reset threshold 


V LVR 


2.8 


3.5 


4.2 


V 


Pull-up resistor 












PA0-PA7, PB2-PB7, PC0-PC7, PD0-PD7 




15 


20 


90 


KC2 


PB0, PB1 


R PU 


1.6 


1.9 


2.9 


KC2 


RESET 




20 


60 


150 


KQ 


IRQ 




60 


100 


300 


KC2 



Notes: 

(1 ) All values shown reflect average measurements. 

(2) Typical values at midpoint of voltage range, 25°C only. 

(3) Wait l DD : Only timer system active. 

(4) Wait, Stop l DD : All ports configured as inputs, V| L =0.2Vdc, V| H =V DD -0.2Vdc. 

(5) Run (operating) l DD , Wait l DD : Measured using external square wave clock source to OSC1 (f O sc=2.0MHz), all inputs 0.2Vdc from rail; no DC loads, less than 50pF on 
all outputs, C L =20pF on OSC2. 

(6) Stop l D rj measured with OSC1=V ss . 

(7) Wait I D d is affected linearly by the OSC2 capacitance. 
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10.4 



Control Timing 



Table 10-2 Control Timing 



(V DD =5.0Vdc ±10%, V ss =0Vdc, temperature range =0 to 70 °C) 



CHARACTERISTICS 


SYMBOL 


MINIMUM 


MAXIMUM 


UNIT 


Frequency of operation 
RC oscillator Option 




0.1 


4.0 


MHz 


Crystal option 

CALCI lldl UUOI\ UfJUUM 


'osc 


0.1 
dr 


4.0 
a n 


MHz 
MHz 


Internal nnocatinn froniionru (f^^nl9\ 

IMLCIMdl UfJcldllML] ICLjUcllby ^QCQ/^ 

RC oscillator 


f OP 




2.0 


MHz 


Crystal 

External clock 


_ 

dc 


2.0 
2.0 


MHz 
MHz 


Processor cycle time (1 /f p) 


*CYC 


500 


— 


ns 


RC oscillator stabilization time 


^RCON 





1 


ms 


Crystal oscillator start-up time (crystal oscillator) 


^OXOV 




100 


ms 


Stop recovery start-up time (crystal oscillator) 


'iLCH 




100 


ms 


RESET pulse width low 


tRL 


1.5 




*CYC 


Timer resolution' 2 ' 


'resl 


4.0 




*CYC 


Interrupt pulse width low (edge-triggered) 


'lUH 


125 




ns 


Interrupt pulse period 


•lUL 


See note (3) 




*CYC 


PA0-PA7 interrupt pulse width high (edge-triggered) 


'iHIL 


125 




ns 


PA0-PA7 interrupt pulse period 


'iHIH 


See note (3) 




*CYC 


OSC1 pulse width 


t 


90 




ns 


RC oscillator frequency combined stability' 4 ' 










f OS c=2.0MHz, V DD =5.0Vdc±10%, t A =-40°C to +85°C 


Af osc 




±25 


% 


f OS c=2.0MHz, V DD =5.0Vdc±10%, t A =0°C to +40°C 


Af osc 




±15 


% 



Notes: 

(1 ) V DD =5.0Vdc±1 0%, V ss =0Vdc, t A =t L to t H 

(2) The TIMER input pin is the limiting factor in determining timer resolution. 

(3) The minimum period t| UL or t| H | H should not be less than the number of cycles it takes to execute the interrupt service routine plus 19 t C Yr> 

(4) Effects of processing, temperature, and supply voltage (excluding tolerances of external R and C). 



MC68HC05SU3A ELECTRICAL SPECIFICATIONS 

For More Information On This Product, iq-3 
Go to: www.freescale.com 



Freescale Semiconductor, Inc. 



THIS PAGE LEFT BLANK INTENTIONALLY 



ELECTRICAL SPECIFICATIONS MC68HC05SU3A 
For More Information On This Product, 
Go to: www.freescale.com 



Freescale Semiconductor, Inc. 



11 

MECHANICAL SPECIFICATIONS 

This section provides the mechanical dimensions for the 40-pin DIP, 42-pin SDIP and 44-pin QFP 
packages for the MC68HC05SU3A. 
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11.1 



40-Pin DIP Package (Case 711-03) 



P 20 



■< A 




rmrnm 

U-H -J U-G -* 




i N :: 


ggggggg m t :: 


LIfJ^d \ kJ 



NOTES: 

1 . POSITIONAL TOLERANCE OF LEADS (D), SHALL 
BE WITHIN 0.25 mm (0.010) AT MAXIMUM 
MATERIAL CONDITION, IN RELATION TO SEATING 
PLANE AND EACH OTHER. 

2. DIMENSION LTO CENTER OF LEADS WHEN 
FORMED PARALLEL. 

3. DIMENSION B DOES NOT INCLUDE MOLD FLASH. 



MILLIMETERS 



INCHES 



2.035 2.065 



0.540 0.560 



3.94 
0.36 



0.155 
0.014 



0.200 
0.022 



1.52 
2.54 BSC 



0.040 | 0.060 
0.100 BSC 



0.008 0.015 



0.115 0.135 



0.020 0.040 



Figure 11-1 40-pin DIP Package 



11.2 



42-Pin SDIP Package (Case 858-01) 




J 42 PL— 



L ► 


«-H-» 




/ 


\ 


I 


I 







| 0.25(0.010)® | T| B© I 



NOTES: 

1 . DIMENSIONS AND TOLERANCING PER ANSI 
Y14.5M, 1982. 

2. CONTROLLING DIMENSION: INCH. 

3. DIMENSION L TO CENTER OF LEAD WHEN 
FORMED PARALLEL. 

4. DIMENSIONS A AND B DO NOT INCLUDE MOLD 
FLASH. MAXIMUM MOLD FLASH 0.25 (0.010). 



INCHES 



MILLIMETERS 



0.014 0.022 0.36 



0.032 0.046 0.81 



0.008 I 0.015 0.20 



0.115 | 0.135 2.92 | 3^43 
0.600 BSC 15.24 BSC 



0.020 0.040 0.51 



Figure 11-2 42-pin SDIP Package 
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11.3 



44-pin QFP Package (Case 824A-01) 










i_ 




/~ B 

Jl 


J 


///// 


N 


t 


D * 


t 



BASE METAL 




DETAIL C 



-| 0.20 (0.008) ® C A-B® D ® | 



SECTION B-B 



/ |o| 0.01 (0.004) | 



DETAIL C 



NOTES: 

1. DIMENSIONING AND TOLERANCING PER ANSI 
Y14.5M,1982. 

2. CONTROLLING DIMENSION: MILLIMETER. 

3. DATUM PLANE -H- IS LOCATED AT BOTTOM OF 
LEAD AND IS COINCIDENT WITH THE LEAD WHERE 
THE LEAD EXITS THE PLASTIC BODY AT THE 
BOTTOM OF THE PARTING LINE. 

4. DATUMS -A-, -B- AND -D- TO BE DETERMINED AT 
DATUM PLANE -H-. 

5. DIMENSIONS S AND V TO BE DETERMINED AT 
SEATING PLANE -C-. 

6. DIMENSIONS A AND B DO NOT INCLUDE MOLD 
PROTRUSION. ALLOWABLE PROTRUSION IS 0.25 
(0.010) PER SIDE. DIMENSIONS A AND B DO 
INCLUDE MOLD MISMATCH AND ARE DETERMINED 
AT DATUM PLANE -H-. 

7. DIMENSION D DOES NOT INCLUDE DAMBAR 
PROTRUSION. ALLOWABLE DAMBAR PROTRUSION 
SHALL BE 0.08 (0.003) TOTAL IN EXCESS OF THE D 
DIMENSION AT MAXIMUM MATERIAL CONDITION. 
DAMBAR CANNOT BE LOCATED ON THE LOWER 
RADIUS OR THE FOOT. 



0.65 | 0.95 
8.00 REF 



BSC 

0.25 



12.95 13.45 



0.031 BSC 
— 0.010 



0.026 | 0.037 
0.315 REF 



Figure 11-3 44-pin QFP Package 
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